-
Notifications
You must be signed in to change notification settings - Fork 300
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add support for containerd v3 configs #805
Conversation
91269ac
to
96934b2
Compare
) | ||
|
||
// ConfigV3 represents a version 3 containerd config | ||
type ConfigV3 Config |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
If the v3 config is the same as the v2 config then we should not duplicate the logic for the functions here.
Are there any differences that are relevant to the runtime sections?
@@ -89,14 +91,16 @@ func New(opts ...Option) (engine.Interface, error) { | |||
return (*ConfigV1)(cfg), nil | |||
case 2: | |||
return cfg, nil | |||
case 3: | |||
return (*ConfigV3)(cfg), nil | |||
} | |||
|
|||
return nil, fmt.Errorf("unsupported config version: %v", version) | |||
} | |||
|
|||
// parseVersion returns the version of the config | |||
func (c *Config) parseVersion(useLegacyConfig bool) (int, error) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We've essentially replaced the useLegacyConfig
variable with the configVersion
option. Would it make sense to update the implementation here to something like:
defaultVersion := 3
if c.configVersion != 0 {
defaultVersion = c.configVersion
}
and drop the useLegacyConfig
argument?
@@ -30,7 +30,7 @@ type builder struct { | |||
configSource toml.Loader | |||
path string | |||
runtimeType string | |||
useLegacyConfig bool | |||
configVersion int64 |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is technically the defaultVersion
since the version in the config file overwrites this.
96934b2
to
c11d433
Compare
@alam0rt I have taken these changes and reworked them. I hope you don't have an issue with me rebasing your commits to get them a little more streamlined. Let me know what you think. |
@cdesiniotis @tariq1890 this is something that will be required for the next GPU Operator release and we could consider backporting this too. |
c11d433
to
5d073fb
Compare
I absolutely do not mind. Thanks for taking a look! Have been a bit inundated so I haven't had a chance to rework it myself |
It looks like |
@alam0rt I have gone ahead and updated this PR with my commit. @elezar @tariq1890 please take a look. |
config.SetPath([]string{"plugins", "cri", "containerd", "default_runtime", "runtime_engine"}, "") | ||
config.SetPath([]string{"plugins", "cri", "containerd", "default_runtime", "privileged_without_host_devices"}, false) | ||
if setAsDefault { | ||
if !c.UseLegacyConfig { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can we invert the if-else block here? It would look more readable if we avoid the NOT statement when possible
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
inverted it
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@tariq1890 I kept the ordering of the blocks the same to reduce the diff against main
. @alam0rt this means that I reverted your commit that inverts the block (which was not signed-off in any case).
RemoveRuntime(string) error | ||
Save(string) (int64, error) | ||
GetRuntimeConfig(string) (RuntimeConfig, error) | ||
Set(string, interface{}) | ||
String() string |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I see that we are only using this in unit tests, do we really need to add a new interface method for this?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Sorry @tariq1890, I missed this. I will have a look again and see if we can clean up the interface as a follow-up.
The issue is that the New
function that we call in tests returns an interface type and adding a String()
function was simpler than adding type casts. Let me see what the latter looks like.
case 1: | ||
return (*ConfigV1)(cfg), nil | ||
case 2: | ||
cfg.CRIRuntimePluginName = "io.containerd.grpc.v1.cri" |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The intent of this switch statement is just to cast the config to the correct type, so instead of doing this here, should we set some local based on the version above and set CRIRuntimePluginName
in the instantiation directly?
I think we could add b.criRuntimePluginName(version)
or something to make this cleaner.
type builder struct { | ||
logger logger.Interface | ||
configSource toml.Loader | ||
configVersion int |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Did we want to allow the CRIRuntimePluginName
to be overridden?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I didn't update this to allow it to be overridden. If we see this as a requirement, plumbing a value through should be relatively straightforward.
Signed-off-by: Evan Lezar <[email protected]>
Signed-off-by: Evan Lezar <[email protected]>
e6f8211
to
c75b67c
Compare
This change adds support for containerd configs with version=3. From the perspective of the runtime configuration the contents of the config are the same. This means that we just have to load the new version and ensure that this is propagated to the generated config. Note that v3 config also requires a switch to the 'io.containerd.cri.v1.runtime' CRI runtime plugin. See: https://github.com/containerd/containerd/blob/v2.0.0/docs/PLUGINS.md containerd/containerd#10132 Note that we still use a default config of version=2 since we need to ensure compatibility with older containerd versions (1.6.x and 1.7.x). Signed-off-by: Sam Lockart <[email protected]> Signed-off-by: Evan Lezar <[email protected]> Signed-off-by: Christopher Desiniotis <[email protected]>
c75b67c
to
95bda3a
Compare
With the release of containerd 2.0 comes a new default config version. This PR attempts to support the new version 3 of the containerd configuration.
Version 3 is fairly similar to 2 and for all intents and purposes, a valid version 3 config is a valid version 2 config (bar the version of course). So for now I've just gone and copied the V2 logic and changed things here and there.